<template>
  <div>
    <van-nav-bar :title="`${$route.query.key} 的搜索结果`" />

    <van-list
      v-model="loading"
      :finished="finished"
      finished-text="没有更多了"
      @load="onLoad"
    >
      <van-cell
        v-for="item in list"
        :key="item.art_id"
        :title="item.title"
        @click="$router.push(`/article?id=${item.art_id}`)"
      />
    </van-list>
  </div>
</template>

<script>
import { searchResultAPI } from "@/api/search";
export default {
  data() {
    return {
      loading: false,
      finished: false,
      list: [],
      page: 1,
    };
  },
  methods: {
    async onLoad() {
      const res = await searchResultAPI({
        page: this.page,
        q: this.$route.query.key,
      });

      // 这次请求完了，代表下次来要查第二页
      this.page++;
      // 添加到数组
      this.list.push(...res.data.results);
      // 结束本次加载状态，可以进行下次
      this.loading = false;

      // 因为数组保存了请求到的数据，所以如果数组的长度大于或等于总数据量
      // 就证明请求加载完了
      if (this.list.length >= res.data.total_count) {
        this.finished = true;
      }
    },
  },
};
</script>

<style>
</style>